﻿<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>GuiControl</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<link href="../css/commands.css" rel="stylesheet" type="text/css">
<link href="../css/print.css" rel="stylesheet" type="text/css" media="print">
</head>
<body>

<h1>GuiControl</h1>

<p>对一个图形用户界面窗口的控件做出种种改变。</p>

<p class="CommandSyntax">GuiControl, Sub-command, ControlID [, Param3] </p>
<h3>参数 </h3>
<table border="1" width="100%" cellspacing="0" cellpadding="3" bordercolor="#C0C0C0">
  <tr>
    <td>Sub-command</td>
    <td>参见下面的列表。</td>
  </tr>
  <tr>
    <td width="15%">ControlID</td>
    <td width="85%"><p>如果目标控件有一个关联的变量，那么将变量名指定为 <em>ControlID</em> (这个方法优先于后面描述的方法)。由于这个原因，通常最好给每一个之后要被 GuiControl 或者 GuiControlGetit 存取的控件指定一个变量名，即使那个控件没有输入功能(例如 GroupBox 或者 Text)。</p>
      <p>如若不然，<em>ControlID</em> 可以是 ClassNN (控件的类名和实例号) 或者控件的名字/文本，这两者都可以通过 Window Spy(窗体侦探) 来决定。当使用名字/文本时，匹配的行为可以由 <a href="SetTitleMatchMode.htm">SetTitleMatchMode</a> 决定。注意：一个图片控件的文件名字 (和控件创建时指定的一样) 可以当做 <em>ControlID</em> 使用。</p></td>
  </tr>
  <tr>
    <td>Param3</td>
    <td>除了下面 sub-commands 列表中说明的，这个参数是被省略的。</td>
  </tr>
</table>

<h3>ErrorLevel</h3>
<p>如果指定的窗体/控件不存在或者其他一些错误导致命令不能工作，<a href="../misc/ErrorLevel.htm">ErrorLevel</a> 被设为 1 。否则，它被设为 0 。</p>
<h3>Sub-commands</h3>
<p><strong>(Blank)</strong> (空白): 将 <em>Sub-command</em> 留空，然后通过 <em>Param3</em> 给予控件新的内容。比如：</p>
<p><a href="GuiControls.htm#Picture">Picture</a>: <em>Param3</em> 应当是要加载的图片的文件名 (支持的文件类型参见 <a href="GuiControls.htm#Picture">Gui Picture</a>)。在文件名的前面可以指定零个或多个下面的参数：*wN (宽度 N), *hN (高度 N), 和 *IconN (DLL 或者 EXE 文件中的图标的组号)。下面的例子中，第二个图标组中的默认的图标载入的宽度是 100 ，通过 &quot;keep aspect ratio&quot; 设置自动高度: <em>GuiControl,, MyPic, *icon2 *w100 *h-1 C:\My Application.exe</em>。指定 <em>*w0 *h0</em> 来使用图像的实际高度和宽度。如果 *w 和 *h 被省略，图像将被缩放来适应当前控件的尺寸。当从多图标的 .ICO 文件载入图标的时候，指定宽度和高度可以决定哪个图标将被载入。注意：在最后一个选择项和文件名之间只能使用一个空格或者制表符；其他任何空格或者制表符将被当做文件名的一部分。</p>
<p><a href="GuiControls.htm#Text">Text</a>/<a href="GuiControls.htm#Button">Button</a>/<a href="GuiControls.htm#GroupBox">GroupBox</a>/<a href="GuiControls.htm#StatusBar">StatusBar</a>: 对于 <em>Param3</em> 指定控件的新文本。因为控件不能自动改变大小，所以如果控件需要变宽，请使用 <em><a href="#Move">GuiControl, Move, MyText, W300</a></em> 。对于 <a href="GuiControls.htm#StatusBar">StatusBar</a>，这个选项仅设置第一部分的文本。(想要更灵活的实现请使用 <a href="GuiControls.htm#SB_SetText">SB_SetText()</a> )。</p>
<p><a href="GuiControls.htm#Edit">Edit</a>: 为了正常显示 <em>Param3</em> 中缺少之前回车 (`r) 的换行 (`n)，它被自动的转换为 CR+LF (`r`n)。然而，这在通常情况下无需考虑，因为 &quot;Gui Submit&quot; 和 &quot;GuiControlGet OutputVar&quot; 命令能自动撤销这一替换，使 CR+LF 变回 LF (`n)。</p>
<p><a href="GuiControls.htm#Hotkey">Hotkey</a>: <em>Param3</em> 可以为空来清除控件，或者一组有键名的修改器。例如：^!c, ^Numpad1, +Home。支持的修改器仅有 ^ (Control), ! (Alt), 和 + (Shift)。可用键名请参见 <a href="../KeyList.htm">key list</a>。</p>
<p><a href="GuiControls.htm#Checkbox">Checkbox</a>: <em>Param3</em> 可以为 0 来不选择按钮，1 来选择，或者 -1 来给它一个灰色的检查标志。另外，<em>Param3</em> 默认是控件的新标题/文本。关于如何重写这一行为，参考下面的 <strong>Text</strong> 。</p>
<p><a href="GuiControls.htm#Radio">Radio</a>: 和上面的 Checkbox 类似。但是，如果单选按钮是选中的 (开启) 而且它是一个单选按钮组中的一项，那么组中其他的单选按钮自动即为未选中的。想要选中一个只有一个变量的单选按钮组中的一个新的按钮并且此按钮不是那个变量直接联系的，请指定按钮的 <em>ControlID</em> 为它的 名字/文本 。</p>
<p><a href="GuiControls.htm#DateTime">DateTime</a>/<a href="GuiControls.htm#MonthCal">MonthCal</a>: 为 <em>Param3</em> 指定一个格式为 <a href="FileSetTime.htm#YYYYMMDD">YYYYMMDDHH24MISS</a> 的日期-时间标记。指定 %A_Now% 来使用当前的日期和时间 (当天)。对于日期时间控件，<em>Param3 </em> 可以省略来使控件不选中日期/时间 (如果它在创建时有 <a href="GuiControls.htm#ChooseNone">that ability</a> (这一能力))。对于 MonthCal 控件，如果它是 <a href="GuiControls.htm#MonthCalMulti">multi-select</a> (多选择的)，那么可以指定一个范围。</p>
<p><a href="GuiControls.htm#UpDown">UpDown</a>/<a href="GuiControls.htm#Slider">Slider</a>/<a href="GuiControls.htm#Progress">Progress</a>: <em>Param3</em> 应当是控件的新位置。如果 <em>Param3</em> 的第一个符号是加号，这个数字就被认为是相对当前位置的偏移值，例如，+10 把位置增加10，而 +-10 (加负十) 把位置减去10。如果新位置在控件的范围之外，控件通常被设置在最近的合法值处。</p>
<p><a href="GuiControls.htm#Tab">Tab</a>/<a href="GuiControls.htm#DropDownList">DropDownList</a>/<a href="GuiControls.htm#ComboBox">ComboBox</a>/<a href="GuiControls.htm#ListBox">ListBox</a>: <em>Param3</em> 应当包含一个管道符分隔的要加在控件后的条目的列表。要替换 (重写) 这个列表，在第一个字符前加上一个管道符 (例如 |Red|Green|Blue)。要将控件置空，只需指定一个管道符 (|)。要预先选定其中一个条目，在它之后加上两个管道符 (例如 Red|Green||Blue)。条目之间的分隔符可以为其他字符，不一定是管道符。比如 <em><a href="Gui.htm#Delimiter">Gui +Delimiter`n</a></em> 可以将它改为换行而 <em>Gui +DelimiterTab</em> 将它改为制表符。</p>
<p><a href="GuiControls.htm#Tab">Tab controls</a>: 除了以上段落描述的行为，一个标签页的子控件和它们原始的标签编号相关联；也就是说，它们永远不与它们的标签页的名字关联。因此，重命名或者删除一个标签页不会改变子控件所属的标签页的编号。例如，有三个标签页 &quot;Red|Green|Blue&quot;，第二个标签页通过 &quot;<em>GuiControl,, MyTab, |Red|Blue</em>&quot; 被移除，原来和 Green 标签页联系的子控件不会和 Blue 标签页关联。因为这一行为，通常情况下只有最后一个标签页才能被移除。用这种方法移除的标签随后还可以再被加进来，那时它们会重新声明原来的控件。</p>
<p><a href="ListView.htm">ListView</a> 和 <a href="TreeView.htm">TreeView</a>: 当 <em>Sub-command</em> 为空时不支持这两个参数。做为替代，请使用内建的 <a href="ListView.htm#BuiltIn">ListView functions</a> 和 <a href="TreeView.htm#BuiltIn">TreeView functions</a>。</p>
<p><strong><br>
    <a name="Text"></a><span class="CommandSyntax">GuiControl</span>, Text</strong>: 除了下面这几个，效果和上面的一样：<br>
<a href="GuiControls.htm#Checkbox">Checkbox</a>/<a href="GuiControls.htm#Radio">Radio</a>: <em>Param3</em> 被当做新的文本/标题，即使它是 -1, 0, 或 1。<br>
<a href="GuiControls.htm#DateTime">DateTime</a>: <em>Param3</em> 被当做控件中显示的新的 <a href="GuiControls.htm#DateTimeFormat">date/time format</a> (日期/时间 格式)。如果 Param3 被省略，任何自定义格式将被移除，短日期格式被使用。<br>
<a href="GuiControls.htm#ComboBox">ComboBox</a>: <em>Param3</em> 被当做文本而直接放在下拉列表框的编辑控件中。</p>
<p><strong><a name="Move"></a><span class="CommandSyntax">GuiControl</span>, Move</strong>: 移动 和/或 缩放控件。在 <em>Param3</em> 中指定下面一个或几个可选字母：X (相对于窗口中用户区域的 x 坐标，即不包括标题栏，菜单栏和边框的区域); Y (y 坐标), W (宽度), H (高度)。例如:</p>
<pre>GuiControl, Move, MyEdit, x10 y20 w200 h100
GuiControl, Move, MyEdit, % &quot;x&quot; VarX+10 &quot;y&quot; VarY+5 &quot;w&quot; VarW*2 &quot;h&quot; VarH*1.5 <em>; 通过 &quot;% &quot; 前缀使用 <a href="../Variables.htm#Expressions">expression</a> (表达式) 。</em></pre>
<p><strong><a name="MoveDraw" id="MoveDraw"></a><span class="CommandSyntax">GuiControl</span>, MoveDraw</strong>: 除了上面 &quot;Move&quot; 的功能，它还重画控件占据的窗口位置。尽管当重复和快速调用时可能会产生闪烁，它解决了在特定控件中绘画的问题，比如在 <a href="GuiControls.htm#GroupBox">GroupBoxes</a> 中。</p>
<p><strong><span class="CommandSyntax">GuiControl</span>, Focus</strong>: 将键盘的焦点设置在控件上。要使有效，窗口通常不能被最小化或者被隐藏。</p>
<p><strong><span class="CommandSyntax">GuiControl</span>, Enable / Disable</strong>: 使控件有效或者失效(灰化)。对于标签页控件，此选项还会使标签的子控件有效或失效。然而，任何通过 &quot;GuiControl Disable&quot; 显示禁止的控件在它的标签页被重新生效后仍然保持失效状态。单词 Disable 或者 Enable 后面可以可选的紧跟着 Zero 或 One。Zero 产生相反的效果。例如，<em>Enable</em> 和 <em>Enable%VarContainingOne%</em> 都使控件生效，但是 <em>Enable%VarContainingZero%</em> 将使它失效。</p>
<p><strong><span class="CommandSyntax">GuiControl</span>, Hide / Show</strong>: 隐藏或者显示控件。对于标签页控件将会隐藏或显示标签下所有的子控件。另外如果你还想同时禁用控件的快捷键 (加下线字母)，通过 &quot;GuiControl Disable&quot; 禁用控件。单词 Hide 或者 Show 后面可以可选的紧跟着 0 or 1。产生相反的效果。例如，<em>Show</em> 和 <em>Show%VarContainingOne%</em> 都显示控件，但是 <em>Show%VarContainingZero%</em> 将隐藏它。</p>
<p><strong><span class="CommandSyntax">GuiControl</span>, Delete (还没有实现)</strong>: 这个子命令现在还不存在。对于一个工作区，使用上面的 <strong>Hide</strong> 和/或 <strong>Disable</strong>，或者通过 <a href="Gui.htm#Destroy">Gui Destroy</a> 销毁或重建整个窗口。</p>
<p><strong><span class="CommandSyntax">GuiControl</span>, Choose, ControlID, N</strong>: 设置列表框，下拉列表，复选框或者标签页中的选区为第 N 个入口。第一个入口 <em>N</em> 对应为 1，第二个入口对应为 2，依次类推 (如果 <em>N</em> 不是整数，下面描述的 ChooseString 方法将被作为替代使用)。与 <a href="Control.htm">Control Choose</a> 不同，这个子命令不会触发任何与控件关联的 <a href="Gui.htm#label">g-label</a> ，除非 <em>N</em> 之前有一个管道符 (即使这样，g-label 仅在新的选区和旧选区不同的情况下被触发，至少对 <a href="GuiControls.htm#Tab">Tab controls</a> 是这样)。例如：GuiControl, Choose, MyListBox, <strong>|3</strong>.</p>
<p>此外要产生一个结束的事件，(例如在列表框中的双击)，请包含两个管道符而不是一个(不支持标签页)。</p>
<p>要选择或者取消选择  <a href="GuiControls.htm#ListBoxMulti">multi-select ListBox</a> (多选列表框)中的<u>所有</u> 选项，参考下面的例子：</p>
<pre>Gui +LastFound  <em>; 避免指定下面的 WinTitle 的需要。</em>
<a href="PostMessage.htm">PostMessage</a>, 0x185, 1, -1, ListBox1  <em>; 选择所有选项。0x185 表示 LB_SETSEL。</em>
<a href="PostMessage.htm">PostMessage</a>, 0x185, 0, -1, ListBox1  <em>; 取消选择所有选项。</em></pre>
<p><strong><span class="CommandSyntax">GuiControl</span>, ChooseString, ControlID, String</strong>: 设置列表框，下拉列表，复选框或者标签页中主要部分和 <em>String</em> 匹配的选区(选择)为入口。搜索不区分大小写。例如，如果一个控件包含项 &quot;UNIX Text&quot;，指定单词 unix (小写) 就足以选中它了。支持管道符和双管道符 (详细请参考上面的 &quot;Choose&quot; )。</p>
<p><strong><span class="CommandSyntax">GuiControl</span>, Font</strong>: 把控件的字体改变为它所在窗口的当前使用的字体，字号，颜色和样式。例如：</p>
<pre><a href="Gui.htm#Font">Gui, Font</a>, s18 cRed Bold, Verdana  <em>; 如果需要，使用类似这样的排列方式给窗口指定一个新的默认字体。</em>
GuiControl, Font, MyEdit  <em>; 使上面的字体对控件生效。</em></pre>
<p><strong><span class="CommandSyntax">GuiControl</span>, +/-Option1 +/-Option2 ... </strong>: 增加或者删除不同的选项或样式。所有的 GUI 选项 (<a href="GuiControls.htm">control-specific</a> 和 <a href="Gui.htm#OtherOptions">general</a>) 都将被识别。下面的例子中， <a href="Gui.htm#AltSubmit">AltSubmit</a> 选项被启用但是控件的 <a href="Gui.htm#label">g-label</a> 被删除：

GuiControl,  +AltSubmit -g, MyListBox</p>
<p>下个例子中，OK 按钮被设为新的默认按钮：<br>
  GuiControl, +Default, OK </p>
<p>尽管 <a href="../misc/Styles.htm">styles</a> (样式) 和 extended styles (扩展的样式) 也会被识别，它们中一些在控件创建以后不能被应用或者被删除。如果被指定的改变中至少一个被成功应用，ErrorLevel 被设为 0 。否则，它被设为 1 来指示没有应用任何改变。即使一个改变被成功应用，控件仍然可能选择忽视它。</p>
<h3>注意</h3>
<p>想要根据窗口号码而不是默认窗口进行操作(参加下面)，在子命令前面加上数字和一个冒号，如下面的例子所示：<br>
GuiControl, 2:Show, MyButton<br>
GuiControl, 2:, MyListBox, Item1|Item2</p>
<p>当任何作为 GUI 操作结果的线程被启动时，一个 GUI <a href="../misc/Threads.htm">thread</a> (线程) 被定义。GUI 操作包括选择 GUI 窗口的菜单栏的一项，或者触发它的 <a href="Gui.htm#label">g-labels</a> 中的一项(比如按下一个按钮)。</p>
<p>GUI 线程的默认窗口号码是启动线程的窗口号码。非GUI 线程使用 1 做为它们的默认窗口号码。</p>

<h3>相关命令</h3>
<p><a href="Gui.htm">Gui</a>, <a href="GuiControlGet.htm">GuiControlGet</a>, <a href="Control.htm">Control</a></p>
<h3>示例</h3>
<pre class="NoIndent">GuiControl,, MyListBox, |Red|Green|Blue  <em>; 用新列表替换当前列表。</em>
GuiControl,, MyEdit, New text line 1.`nNew text line 2.
GuiControl,, MyRadio2, 1  <em>; 选择这一单选按钮，不选择组中其他的。</em>
GuiControl, Move, OK, x100 y200  <em>; 移动 OK 按钮到一个新位置。</em>
GuiControl, Focus, LastName  <em>; 把键盘焦点设置在变量或者文本为 &quot;LastName&quot; 的控件上。</em></pre>

</body>
</html>
